

# DesignWare® Cores LPDDR5/4/4X Memory Controller

**Release Notes** 

DWC LPDDR5/4/4X Controller – Product Code: E092-0 DWC LPDDR5/4/4X Controller AFP – Product Code: E093-0 DWC AP LPDDR5/4/4X Controller – Product Code: E094-0

# **Copyright Notice and Proprietary Information**

© 2021 Synopsys, Inc. All rights reserved. This Synopsys software and all associated documentation are proprietary to Synopsys, Inc. and may only be used pursuant to the terms and conditions of a written license agreement with Synopsys, Inc. All other use, reproduction, modification, or distribution of the Synopsys software or the associated documentation is strictly prohibited.

#### **Destination Control Statement**

All technical data contained in this publication is subject to the export control laws of the United States of America. Disclosure to nationals of other countries contrary to United States law is prohibited. It is the reader's responsibility to determine the applicable regulations and to comply with them.

#### **Disclaimer**

SYNOPSYS, INC., AND ITS LICENSORS MAKE NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.

#### **Trademarks**

Synopsys and certain Synopsys product names are trademarks of Synopsys, as set forth at https://www.synopsys.com/company/legal/trademarks-brands.html

All other product or company names may be trademarks of their respective owners.

# Free and Open-Source Software Licensing Notices

If applicable, Free and Open-Source Software (FOSS) licensing notices are available in the product installation.

# **Third-Party Links**

Any links to third-party websites included in this document are for your convenience only. Synopsys does not endorse and is not responsible for such websites and their practices, including privacy practices, availability, and content.

Synopsys, Inc.

www.synopsys.com

1

# LPDDR5/4/4X Memory Controller Release

# **Notes**

This release note describes the changes for release 1.10a-lca00 of the DesignWare Cores LPDDR5/4/4X. The following topics are covered:

- "STARs on the Web" on page 3
- "PHY Versions" on page 3
- "Fixed Defects and Enhancements" on page 4
- "Known Issues and Limitations" on page 17



This release supports a limited number of configurations.

Contact Synopsys to check whether your configuration is supported.

Contact Synopsys if you intend to tape-out your configuration with this release, for confirmation that the configuration is supported for tape-out.

# 1.1 STARs on the Web

You can view a complete list of problem reports for this product, including problems identified after product release, by accessing the STAR reports (STARs on the Web). You must have a SolvNet ID to view STAR reports.

# DWC\_ddrctl\_lpddr54:

https://www.synopsys.com/dw/ipdir.php?c=dwc\_lpddr54\_controller

# 1.2 PHY Versions

This release contains the following DWC LPDDR5/4/4X PHY versions:

■ PUB: 2.20a

PHYINIT: C-2021.06FIRMWARE: C-2021.06

# 1.3 Fixed Defects and Enhancements

# 1.3.1 1.10a-lca00

# 1.3.1.1 Fixed Defects

- HWFFC flow is corrupted in certain conditions.
- DRAMSET1TMG2.rd2wr must be used in 16B mode.
- Automotive documentation must exist in workspace/automotive folder.
- Does not re-assert dfi\_lp\_data\_req after ctrlupd/phyupd at low speed device.
- Documentation typo in Address Mapping for LPDDR5.
- SCHED0, SCHED3 and SCHED4 registers must be static.
- LPDDR5 Derate: Maximum interval between two refreshes limitation can be violated in 1.3x refresh rate.
- dfi\_lp\_data\_req is not deasserted before assertion of dfi\_init\_start during HWFFC.
- Critical REFpb is blocked by ACTIVATE.
- Scrubber burst length is not equal to the programmed burst length register field.

# 1.3.1.2 Enhancements

- Enhanced incremental Periodic Phase Training (PPT2).
- Automatic switching from REFpb to REFab in case of derating for LPDDR5/4.
- [LPDDR5A] Support tCSLCK for WCK.
- Optimized PERFWR1.w\_xact\_run\_length behavior for enhanced RDWR switch.
- Increased maximum width of MEMC\_HIF\_TAGBITS and MEMC\_HIF\_WDATA\_PTR\_BITS.
- Simplified TMGCFG.dfi\_freq\_fsp by removing replicated ones per frequency.
- Propagate Uncorrectable Read Link ECC Error to AXI-RRESP or HIF sideband signal.
- LPDDR5A: RTL update for timing gap between PDX and the next command.
- Removed unused ports from LPDDR DDRCTL interface post 1.01a-lca01 release.
- [JESD209-5A] 7.7.5 Refresh Management Command (RFM).
- Clarification of LPDDR5 WCK related parameters.
- Stop critical refresh burst when disabling automatic refresh.
- LPDDR5/4/4X Code cleanup post 1.01a-lca01 release.
- [JESD209-5A] Added 7.7.9.1 CAS-command-based Enhanced WCK Always On Mode.
- Support for parameter combinations of Link ECC and OCCAP.
- Hide hardware parameter MEMC\_RDWR\_SWITCH\_POL\_SEL and changed default value to 0.
- Minimized command gap between ACT and PRE to the same bank for performance improvement.
- Removed DRAMSET1TMG8 register (not used in LPDDR54).
- [LPDDR5A] Added a constraint from WRA to PDE.

■ Enabled bypass path in XPI\_RMW to be used when RMWs are not needed.

# 1.3.1.3 Hardware Parameter Changes

The following Hardware parameters have been added:

- DDRCTL\_CHB\_TSZ\_REG\_NUM
- DDRCTL\_CHB\_TZ\_EN
- DDRCTL\_PPT2
- DDRCTL\_XPI\_USE\_RMWR

The following Hardware parameters have been deleted:

- MEMC ENH CAM PTR
- MEMC\_ENH\_RDWR\_SWITCH
- MEMC\_FREQ\_RATIO
- MEMC OPT WDATARAM
- MEMC\_RDWR\_SWITCH\_POL\_SEL

For details, refer to the "Parameter Descriptions" chapter of the databook.

# 1.3.1.4 Signal Changes

The following signals have been added:

- dfi0\_ctrlupd\_type
- dfil\_ctrlupd\_type
- hif\_rdata\_eapar\_err
- hif\_rdata\_eapar\_err\_dch1
- hif\_rdata\_uncorr\_linkecc\_err
- perf\_op\_is\_cas\_wck\_sus
- perf\_op\_is\_cas\_wck\_sus\_dch1
- perf\_op\_is\_cas\_ws\_off
- perf\_op\_is\_cas\_ws\_off\_dch1
- perf\_op\_is\_rfm
- perf\_op\_is\_rfm\_dch1

The following signals have been deleted:

- perf\_bypass\_bank
- perf\_bypass\_bank\_dch1
- perf\_bypass\_bg
- perf\_bypass\_bg\_dch1
- perf\_bypass\_cid
- perf\_bypass\_cid\_dch1

- perf\_bypass\_rank
- perf\_bypass\_rank\_dch1

# The following signals have been changed:

- PortWidth of signal dfi0\_address\_P0 changed from work.DWC\_ddrctl\_cc\_constants.svh.MEMC\_DFI\_ADDR\_WIDTH to work.DWC ddrctl cc constants.svh.MEMC DFI ADDR WIDTH P0.
- PortWidth of signal dfi0\_address\_P1 changed from work.DWC\_ddrctl\_cc\_constants.svh.MEMC\_DFI\_ADDR\_WIDTH to work.DWC\_ddrctl\_cc\_constants.svh.MEMC\_DFI\_ADDR\_WIDTH\_P1.
- PortWidth of signal dfi0\_address\_P2 changed from work.DWC\_ddrctl\_cc\_constants.svh.MEMC\_DFI\_ADDR\_WIDTH to work.DWC\_ddrctl\_cc\_constants.svh.MEMC\_DFI\_ADDR\_WIDTH\_P2.
- PortWidth of signal dfi0\_address\_P3 changed from work.DWC\_ddrctl\_cc\_constants.svh.MEMC\_DFI\_ADDR\_WIDTH to work.DWC\_ddrctl\_cc\_constants.svh.MEMC\_DFI\_ADDR\_WIDTH\_P3.
- PortWidth of signal dfil\_address\_P0 changed from work.DWC\_ddrctl\_cc\_constants.svh.MEMC\_DFI\_ADDR\_WIDTH to work.DWC\_ddrctl\_cc\_constants.svh.MEMC\_DFI\_ADDR\_WIDTH\_P0.
- PortWidth of signal dfil\_address\_P1 changed from work.DWC\_ddrctl\_cc\_constants.svh.MEMC\_DFI\_ADDR\_WIDTH to work.DWC\_ddrctl\_cc\_constants.svh.MEMC\_DFI\_ADDR\_WIDTH\_P1.
- PortWidth of signal dfi1\_address\_P2 changed from work.DWC\_ddrctl\_cc\_constants.svh.MEMC\_DFI\_ADDR\_WIDTH to work.DWC\_ddrctl\_cc\_constants.svh.MEMC\_DFI\_ADDR\_WIDTH\_P2.
- PortWidth of signal dfil\_address\_P3 changed from work.DWC\_ddrctl\_cc\_constants.svh.MEMC\_DFI\_ADDR\_WIDTH to work.DWC\_ddrctl\_cc\_constants.svh.MEMC\_DFI\_ADDR\_WIDTH\_P3.

For details, refer to the "Signal Descriptions" chapter of the databook.

# 1.3.1.5 Register Changes

The following registers have been added:

- REGB\_ARB\_PORTO.PCFGW.snf\_mode
- REGB\_ARB\_PORT10.PCFGW.snf\_mode
- REGB\_ARB\_PORT11.PCFGW.snf\_mode
- REGB\_ARB\_PORT12.PCFGW.snf\_mode
- REGB\_ARB\_PORT13.PCFGW.snf\_mode
- REGB\_ARB\_PORT14.PCFGW.snf\_mode
- REGB ARB PORT15.PCFGW.snf mode
- REGB\_ARB\_PORT1.PCFGW.snf\_mode
- REGB\_ARB\_PORT2.PCFGW.snf\_mode
- REGB\_ARB\_PORT3.PCFGW.snf\_mode

- REGB ARB PORT4.PCFGW.snf mode
- REGB\_ARB\_PORT5.PCFGW.snf\_mode
- REGB\_ARB\_PORT6.PCFGW.snf\_mode
- REGB\_ARB\_PORT7.PCFGW.snf\_mode
- REGB\_ARB\_PORT8.PCFGW.snf\_mode
- REGB ARB PORT9.PCFGW.snf mode
- REGB\_DDRC\_CH0.DFIMISC.dfi\_freq\_fsp
- REGB\_DDRC\_CH0.MSTR4.wck\_suspend\_en
- REGB\_DDRC\_CH0.MSTR4.ws\_off\_en
- REGB\_DDRC\_CH0.PPT2CTRL0.ppt2\_burst
- REGB\_DDRC\_CH0.PPT2CTRL0.ppt2\_burst\_num
- REGB\_DDRC\_CH0.PPT2CTRL0.ppt2\_ctrlupd\_num\_dfi0
- REGB\_DDRC\_CH0.PPT2CTRL0.ppt2\_ctrlupd\_num\_dfi1
- REGB\_DDRC\_CH0.PPT2CTRL0.ppt2\_wait\_ref
- REGB\_DDRC\_CH0.PPT2STAT0.ppt2\_burst\_busy
- REGB\_DDRC\_CH0.PPT2STAT0.ppt2\_state
- REGB\_DDRC\_CH0.RFMMOD0.raadec
- REGB\_DDRC\_CH0.RFMMOD0.raaimt
- REGB\_DDRC\_CH0.RFMMOD0.raamult
- REGB\_DDRC\_CH0.RFMMOD0.rfm\_en
- REGB DDRC CHO.RFMMODO.rfmsbc
- REGB DDRC CH0.RFMMOD0.rfmth rm thr
- REGB\_DDRC\_CH0.SCHED0.prefer\_read
- REGB\_DDRC\_CH1.MSTR4.wck\_suspend\_en
- REGB\_DDRC\_CH1.MSTR4.ws\_off\_en
- REGB\_FREQ0\_CH0.DFIUPDTMG2.dfi\_t\_ctrlupd\_interval\_type1
- REGB FREQ0 CH0.DFIUPDTMG2.dfi t ctrlupd interval type1 unit
- REGB FREQ0 CH0.DFIUPDTMG2.ppt2 en
- REGB\_FREQ0\_CH0.DRAMSET1TMG32.t\_wcksus
- REGB\_FREQO\_CHO.DRAMSET1TMG32.ws\_fs2wck\_sus
- REGB FREQ0 CH0.DRAMSET1TMG32.ws off2ws fs
- REGB\_FREQO\_CHO.RFMSET1TMGO.t\_rfmpb
- REGB FREQ0 CH0.RFSHSET1TMG1.t rfc min ab
- REGB\_FREQ0\_CH0.RFSHSET1TMG3.refresh\_to\_ab\_x32
- REGB\_FREQ0\_CH1.DRAMSET1TMG32.t\_wcksus
- REGB\_FREQO\_CH1.DRAMSET1TMG32.ws\_fs2wck\_sus
- REGB\_FREQ0\_CH1.DRAMSET1TMG32.ws\_off2ws\_fs

- REGB FREQ0 CH1.RFMSET1TMG0.t rfmpb
- REGB\_FREQO\_CH1.RFSHSET1TMG1.t\_rfc\_min\_ab
- REGB\_FREQ0\_CH1.RFSHSET1TMG3.refresh\_to\_ab\_x32
- REGB\_FREQ1\_CH0.DFIUPDTMG2.dfi\_t\_ctrlupd\_interval\_type1
- REGB\_FREQ1\_CH0.DFIUPDTMG2.dfi\_t\_ctrlupd\_interval\_type1\_unit
- REGB\_FREQ1\_CH0.DFIUPDTMG2.ppt2\_en
- REGB\_FREQ1\_CH0.DRAMSET1TMG32.t\_wcksus
- REGB\_FREQ1\_CH0.DRAMSET1TMG32.ws\_fs2wck\_sus
- REGB\_FREQ1\_CH0.DRAMSET1TMG32.ws\_off2ws\_fs
- REGB\_FREQ1\_CH0.RFMSET1TMG0.t\_rfmpb
- REGB\_FREQ1\_CH0.RFSHSET1TMG1.t\_rfc\_min\_ab
- REGB\_FREQ1\_CH0.RFSHSET1TMG3.refresh\_to\_ab\_x32
- REGB\_FREQ1\_CH1.DRAMSET1TMG32.t\_wcksus
- REGB\_FREQ1\_CH1.DRAMSET1TMG32.ws\_fs2wck\_sus
- REGB\_FREQ1\_CH1.DRAMSET1TMG32.ws\_off2ws\_fs
- REGB\_FREQ1\_CH1.RFMSET1TMG0.t\_rfmpb
- REGB\_FREQ1\_CH1.RFSHSET1TMG1.t\_rfc\_min\_ab
- REGB\_FREQ1\_CH1.RFSHSET1TMG3.refresh\_to\_ab\_x32
- REGB\_FREQ2\_CH0.DFIUPDTMG2.dfi\_t\_ctrlupd\_interval\_type1
- REGB\_FREQ2\_CH0.DFIUPDTMG2.dfi\_t\_ctrlupd\_interval\_type1\_unit
- REGB\_FREQ2\_CH0.DFIUPDTMG2.ppt2\_en
- REGB FREQ2 CH0.DRAMSET1TMG32.t wcksus
- REGB\_FREQ2\_CH0.DRAMSET1TMG32.ws\_fs2wck\_sus
- REGB\_FREQ2\_CH0.DRAMSET1TMG32.ws\_off2ws\_fs
- REGB\_FREQ2\_CH0.RFMSET1TMG0.t\_rfmpb
- REGB\_FREQ2\_CH0.RFSHSET1TMG1.t\_rfc\_min\_ab
- REGB FREQ2 CH0.RFSHSET1TMG3.refresh to ab x32
- REGB FREQ2 CH1.DRAMSET1TMG32.t wcksus
- REGB\_FREQ2\_CH1.DRAMSET1TMG32.ws\_fs2wck\_sus
- REGB\_FREQ2\_CH1.DRAMSET1TMG32.ws\_off2ws\_fs
- REGB\_FREQ2\_CH1.RFMSET1TMG0.t\_rfmpb
- REGB\_FREQ2\_CH1.RFSHSET1TMG1.t\_rfc\_min\_ab
- REGB\_FREQ2\_CH1.RFSHSET1TMG3.refresh\_to\_ab\_x32
- REGB\_FREQ3\_CH0.DFIUPDTMG2.dfi\_t\_ctrlupd\_interval\_type1
- REGB\_FREQ3\_CH0.DFIUPDTMG2.dfi\_t\_ctrlupd\_interval\_type1\_unit
- REGB\_FREQ3\_CH0.DFIUPDTMG2.ppt2\_en
- REGB\_FREQ3\_CH0.DRAMSET1TMG32.t\_wcksus

- REGB FREQ3 CHO.DRAMSET1TMG32.ws fs2wck sus
- REGB\_FREQ3\_CHO.DRAMSET1TMG32.ws\_off2ws\_fs
- REGB\_FREQ3\_CH0.RFMSET1TMG0.t\_rfmpb
- REGB\_FREQ3\_CH0.RFSHSET1TMG1.t\_rfc\_min\_ab
- REGB\_FREQ3\_CH0.RFSHSET1TMG3.refresh\_to\_ab\_x32
- REGB FREQ3 CH1.DRAMSET1TMG32.t wcksus
- REGB\_FREQ3\_CH1.DRAMSET1TMG32.ws\_fs2wck\_sus
- REGB\_FREQ3\_CH1.DRAMSET1TMG32.ws\_off2ws\_fs
- REGB\_FREQ3\_CH1.RFMSET1TMG0.t\_rfmpb
- REGB\_FREQ3\_CH1.RFSHSET1TMG1.t\_rfc\_min\_ab
- REGB\_FREQ3\_CH1.RFSHSET1TMG3.refresh\_to\_ab\_x32

# The following registers have been deleted:

- REGB\_ARB\_PORTO.SBRCTL.sbr\_correction\_mode
- REGB\_ARB\_PORTO.SBRSTAT.scrub\_drop\_cnt
- REGB\_ARB\_PORT0.SBRSTAT.scrub\_drop\_cnt\_dch1
- REGB\_DDRC\_CH0.ECCCFG2.bypass\_internal\_ecc
- REGB\_DDRC\_CH0.ECCCFG2.flip\_bit\_pos0
- REGB\_DDRC\_CH0.ECCCFG2.flip\_bit\_pos1
- REGB\_DDRC\_CH0.HWFFCCTL.hwffc\_odt\_en
- REGB DDRC CHO.HWFFCCTL.hwffc vref en
- REGB\_DDRC\_CH0.OPCTRL0.dis\_collision\_page\_opt
- REGB FREQ0 CH0.DRAMSET1TMG8.t xs dll x32
- REGB\_FREQ0\_CH0.DRAMSET1TMG8.t\_xs\_x32
- REGB\_FREQO\_CHO.DRAMSET2TMG31.rfm\_raaimt\_2
- REGB\_FREQ0\_CH0.DRAMSET2TMG31.rfm\_raa\_ref\_decr\_2
- REGB FREQ0 CH0.DRAMSET2TMG31.rfm raa thr 2
- REGB\_FREQ0\_CH0.TMGCFG.dfi\_freq\_fsp
- REGB\_FREQ0\_CH1.DRAMSET1TMG8.t\_xs\_dl1\_x32
- REGB\_FREQ0\_CH1.DRAMSET1TMG8.t\_xs\_x32
- REGB\_FREQO\_CH1.DRAMSET2TMG31.rfm\_raaimt\_2
- REGB\_FREQ0\_CH1.DRAMSET2TMG31.rfm\_raa\_ref\_decr\_2
- REGB\_FREQ0\_CH1.DRAMSET2TMG31.rfm\_raa\_thr\_2
- REGB\_FREQ1\_CH0.DRAMSET1TMG8.t\_xs\_dl1\_x32
- REGB FREQ1 CHO.DRAMSET1TMG8.t xs x32
- REGB\_FREQ1\_CH0.DRAMSET2TMG31.rfm\_raaimt\_2
- REGB\_FREQ1\_CH0.DRAMSET2TMG31.rfm\_raa\_ref\_decr\_2
- REGB\_FREQ1\_CH0.DRAMSET2TMG31.rfm\_raa\_thr\_2

- REGB\_FREQ1\_CH0.TMGCFG.dfi\_freq\_fsp
- REGB\_FREQ1\_CH1.DRAMSET1TMG8.t\_xs\_dl1\_x32
- REGB\_FREQ1\_CH1.DRAMSET1TMG8.t\_xs\_x32
- REGB FREQ1 CH1.DRAMSET2TMG31.rfm raaimt 2
- REGB\_FREQ1\_CH1.DRAMSET2TMG31.rfm\_raa\_ref\_decr\_2
- REGB FREQ1 CH1.DRAMSET2TMG31.rfm raa thr 2
- REGB\_FREQ2\_CH0.DRAMSET1TMG8.t\_xs\_dll\_x32
- REGB\_FREQ2\_CH0.DRAMSET1TMG8.t\_xs\_x32
- REGB\_FREQ2\_CH0.DRAMSET2TMG31.rfm\_raaimt\_2
- REGB FREQ2 CH0.DRAMSET2TMG31.rfm raa ref decr 2
- REGB\_FREQ2\_CH0.DRAMSET2TMG31.rfm\_raa\_thr\_2
- REGB\_FREQ2\_CH0.TMGCFG.dfi\_freq\_fsp
- REGB\_FREQ2\_CH1.DRAMSET1TMG8.t\_xs\_dl1\_x32
- REGB\_FREQ2\_CH1.DRAMSET1TMG8.t\_xs\_x32
- REGB\_FREQ2\_CH1.DRAMSET2TMG31.rfm\_raaimt\_2
- REGB\_FREQ2\_CH1.DRAMSET2TMG31.rfm\_raa\_ref\_decr\_2
- REGB\_FREQ2\_CH1.DRAMSET2TMG31.rfm\_raa\_thr\_2
- REGB\_FREQ3\_CH0.DRAMSET1TMG8.t\_xs\_dl1\_x32
- REGB\_FREQ3\_CH0.DRAMSET1TMG8.t\_xs\_x32
- REGB\_FREQ3\_CH0.DRAMSET2TMG31.rfm\_raaimt\_2
- REGB\_FREQ3\_CH0.DRAMSET2TMG31.rfm\_raa\_ref\_decr\_2
- REGB\_FREQ3\_CH0.DRAMSET2TMG31.rfm\_raa\_thr\_2
- REGB\_FREQ3\_CH0.TMGCFG.dfi\_freq\_fsp
- REGB\_FREQ3\_CH1.DRAMSET1TMG8.t\_xs\_dl1\_x32
- REGB\_FREQ3\_CH1.DRAMSET1TMG8.t\_xs\_x32
- REGB\_FREQ3\_CH1.DRAMSET2TMG31.rfm\_raaimt\_2
- REGB FREQ3 CH1.DRAMSET2TMG31.rfm raa ref decr 2
- REGB FREQ3 CH1.DRAMSET2TMG31.rfm raa thr 2

# The following registers have been changed:

- RegisterResetValue of register REGB\_DDRC\_CHO.DDRCTL\_VER\_NUMBER.ver\_number changed from 0x3130312a to 0x3131302a.
- RegisterResetValue of register REGB\_DDRC\_CH0.DDRCTL\_VER\_TYPE.ver\_type changed from 0x6c633031 to 0x736f3031.
- Name of register REGB\_DDRC\_CH0.RFSHMOD0.mixed\_refsb\_hi\_thr changed from REGB\_DDRC\_CH0.RFSHMOD0.mixed\_refsb\_hi\_thr to REGB\_DDRC\_CH0.RFSHMOD0.auto\_refab\_en.
- RegisterResetValue of register REGB\_DDRC\_CH0.RFSHMOD0.mixed\_refsb\_hi\_thr changed from 0xf to 0x0.

For details, refer to the "Register Descriptions" chapter of the Programming Guide.

## 1.3.2 1.01a-lca01

# 1.3.2.1 Fixed Defects

- Controller Assisted Drift Tracking is not initiated while DRAM is put into power down (STAR 3441761).
- perf\_op\_is\_tcr\_mrr is asserted even when an MRR command is issued other than to MR4 (STAR 3482346).
- Assert duration of perf\_op\_is\_zqstart is not always one DFI clock cycle (STAR 3375678).
- In LPDDR4 mode, SRE/SRX/PDE/PDX is issued for both ranks irrespective of MSTR0.active\_ranks (STAR 3395111).
- Scrubber sends less than expected number of transactions in the last scrub burst.
- HIF timing diagrams for DFI 1:2/1:1:2 frequency ratio mode are incorrect in "Channel Modes" chapter of DWC LPDDR5/4/4X Memory Controller Databook (STAR 3375680).
- The description of the w\_max\_starve feature is not correct in the Programming Guide (STAR 3440863).

# 1.3.2.2 Enhancements

- Changed bit width of dfi\*\_address\_P<0-3> from 20 to 14 because higher 6 bits were unused/redundant
- Restrict reliability features with AP/AFP licenses
- Added support for HBW mode [only with MEMC\_DRAM\_DATA\_WIDTH=32 and 16-bit PHY]
- dfi\*\_phymstr\_ack and dfi\*\_phyupd\_ack will now assert exclusively when both dfi\*\_phymstr\_req and dfi\*\_phyupd\_req assert (applicable when used with 3rd party PHYs)
- Added support for single rank LPDDR4/4X HWFFC
- Optimized XPI RRB for timing closure
- Improved clock gating in DWC\_ddr\_umctl2\_datasync.v module
- Added support for Fusion Compiler
- Support for architectural clock gating of BSMs during low power states to reduce power consumption
- Improved CDC ack logic for registers containing R/W1S and R/W1C fields
- Improved control of starvation timer for WR CAM threshold when WR is issued
- Added register parity protection to LINKECCERRSTAT
- [LPDDR5A] 7.5.1 Refresh command Update burst REFab constraints
- Added VC SpyGlass support

# 1.3.2.3 Hardware Parameter Changes

The following Hardware parameters have been added:

- DDRCTL\_CAPAR\_CMDFIFO\_DEPTH
- DDRCTL CAPAR RETRY
- DDRCTL\_CHB\_WRB\_RAM\_RD\_ADDR\_REG\_OUT

SolvNetPlus

DesignWare

- DDRCTL CHB WRB RAM RD DATA REG IN
- DDRCTL\_CHB\_WRB\_RAM\_WR\_REG\_OUT
- DDRCTL\_CHB\_WR\_PROTQ\_SIZE
- DDRCTL\_ENH\_ECC\_REPORT\_EN
- DDRCTL\_HW\_RFM\_CTRL
- DDRCTL NUM BITS PER KBD
- DDRCTL\_PBW\_MODE\_SUPPORT
- DDRCTL\_RSD\_PIPELINE
- DDRCTL\_SW\_RDWR\_EN
- UMCTL2 OCCAP PIPELINE

# The following Hardware parameters have been deleted:

- UMCTL2\_RETRY\_CMD\_FIFO\_DEPTH
- UMCTL2\_RETRY\_MAX\_ADD\_RD\_LAT
- UMCTL2\_RETRY\_WDATA\_EXTERNAL\_SRAM
- UMCTL2\_RETRY\_WDATA\_EXTRAM\_AW
- UMCTL2\_RETRY\_WDATA\_EXTRAM\_DEPTH
- UMCTL2\_RETRY\_WDATA\_EXTRAM\_DW

# The following Hardware parameters have been changed:

- Default Value of HW parameter DDRCTL\_RETRY\_FIFO\_DEPTH changed from 24 to 40.
- Value of HW parameter DDRCTL\_RETRY\_FIFO\_DEPTH changed from 24 to 40.
- Default Value of HW parameter MEMC\_NUM\_TOTAL\_BANKS changed from 16 to 0x10.
- Value of HW parameter MEMC\_NUM\_TOTAL\_BANKS changed from 16 to 0x10.

For details, refer to the "Parameter Descriptions" chapter of the databook.

# 1.3.2.4 Signal Changes

The following signals have been added:

- bsm clk
- hif\_wdata\_kbd
- hif\_wdata\_kbd\_dch1
- bsm\_clk\_en
- hif\_rdata\_kbd
- hif rdata kbd dch1

# The following signals have been deleted:

- hif\_wdata\_ecc
- hif\_wdata\_ecc\_dch1
- hif\_wdata\_mask\_ecc

- hif\_wdata\_mask\_ecc\_dch1
- dbg\_resp\_ecc\_data
- dbg\_resp\_ecc\_data\_dch1
- dbg\_rxdata\_ecc
- dbg\_rxdata\_ecc\_dch1
- dbg\_rxdata\_mask\_ecc
- dbg\_rxdata\_mask\_ecc\_dch1
- hif\_rdata\_ecc
- hif\_rdata\_ecc\_dch1
- mpam\_ns\_err\_intr
- mpam\_s\_err\_intr

For details, refer to the "Signal Descriptions" chapter of the databook.

# 1.3.2.5 Register Changes

The following registers have been added:

- REGB\_DDRC\_CH0.ECCCSYN2.cb\_corr\_syndrome
- REGB\_DDRC\_CHO.ECCSTAT.sbr\_read\_ecc\_ce
- REGB\_DDRC\_CH0.ECCSTAT.sbr\_read\_ecc\_ue
- REGB\_DDRC\_CH0.ECCUSYN2.cb\_uncorr\_syndrome
- REGB\_DDRC\_CH0.HWFFCCTL.cke\_power\_down\_mode
- REGB\_DDRC\_CH0.HWFFCCTL.ctrl\_word\_num
- REGB\_DDRC\_CH0.HWFFCCTL.hwffc\_en
- REGB\_DDRC\_CH0.HWFFCCTL.init\_fsp
- REGB\_DDRC\_CH0.HWFFCCTL.init\_vrcg
- REGB\_DDRC\_CH0.HWFFCCTL.power\_saving\_ctrl\_word
- REGB\_DDRC\_CH0.HWFFCCTL.skip\_mrw\_odtvref
- REGB\_DDRC\_CH0.HWFFCCTL.target\_vrcg
- REGB\_DDRC\_CHO.HWFFCSTAT.current\_frequency
- REGB\_DDRC\_CHO.HWFFCSTAT.current\_fsp
- REGB\_DDRC\_CH0.HWFFCSTAT.current\_vrcg
- REGB\_DDRC\_CH0.HWFFCSTAT.hwffc\_in\_progress
- REGB\_DDRC\_CH0.HWFFCSTAT.hwffc\_operating\_mode
- REGB\_DDRC\_CH0.RFSHMOD0.mixed\_refsb\_hi\_thr
- REGB\_DDRC\_CH1.ECCCSYN2.cb\_corr\_syndrome
- REGB\_DDRC\_CH1.ECCSTAT.sbr\_read\_ecc\_ce
- REGB\_DDRC\_CH1.ECCSTAT.sbr\_read\_ecc\_ue
- REGB\_DDRC\_CH1.ECCUSYN2.cb\_uncorr\_syndrome

- REGB\_DDRC\_CH1.HWFFCSTAT.current\_frequency
- REGB\_DDRC\_CH1.HWFFCSTAT.current\_fsp
- REGB\_DDRC\_CH1.HWFFCSTAT.current\_vrcg
- REGB\_DDRC\_CH1.HWFFCSTAT.hwffc\_in\_progress
- REGB\_DDRC\_CH1.HWFFCSTAT.hwffc\_operating\_mode
- REGB\_FREQO\_CHO.DRAMSET1TMG17.t\_vrcg\_disable
- REGB\_FREQ0\_CH0.DRAMSET1TMG17.t\_vrcg\_enable
- REGB\_FREQO\_CH1.DRAMSET1TMG17.t\_vrcg\_disable
- REGB\_FREQO\_CH1.DRAMSET1TMG17.t\_vrcg\_enable
- REGB FREQ1 CH0.DRAMSET1TMG17.t vrcq disable
- REGB\_FREQ1\_CH0.DRAMSET1TMG17.t\_vrcg\_enable
- REGB\_FREQ1\_CH1.DRAMSET1TMG17.t\_vrcg\_disable
- REGB\_FREQ1\_CH1.DRAMSET1TMG17.t\_vrcg\_enable
- REGB\_FREQ2\_CH0.DRAMSET1TMG17.t\_vrcg\_disable
- REGB\_FREQ2\_CH0.DRAMSET1TMG17.t\_vrcg\_enable
- REGB\_FREQ2\_CH1.DRAMSET1TMG17.t\_vrcg\_disable
- REGB\_FREQ2\_CH1.DRAMSET1TMG17.t\_vrcg\_enable
- REGB\_FREQ3\_CH0.DRAMSET1TMG17.t\_vrcg\_disable
- REGB\_FREQ3\_CH0.DRAMSET1TMG17.t\_vrcg\_enable
- REGB\_FREQ3\_CH1.DRAMSET1TMG17.t\_vrcg\_disable
- REGB\_FREQ3\_CH1.DRAMSET1TMG17.t\_vrcg\_enable

# The following registers have been deleted:

- REGB\_ARB\_PORT0.PCHBLCTRL.txsactive\_en
- REGB\_ARB\_PORT10.PCHBLCTRL.txsactive\_en
- REGB\_ARB\_PORT11.PCHBLCTRL.txsactive\_en
- REGB ARB PORT12.PCHBLCTRL.txsactive en
- REGB\_ARB\_PORT13.PCHBLCTRL.txsactive\_en
- REGB\_ARB\_PORT14.PCHBLCTRL.txsactive\_en
- REGB\_ARB\_PORT15.PCHBLCTRL.txsactive\_en
- REGB\_ARB\_PORT1.PCHBLCTRL.txsactive\_en
- REGB\_ARB\_PORT2.PCHBLCTRL.txsactive\_en
- REGB ARB PORT3.PCHBLCTRL.txsactive en
- REGB\_ARB\_PORT4.PCHBLCTRL.txsactive\_en
- REGB ARB PORT5.PCHBLCTRL.txsactive en
- REGB ARB PORT6.PCHBLCTRL.txsactive en
- REGB\_ARB\_PORT7.PCHBLCTRL.txsactive\_en
- REGB\_ARB\_PORT8.PCHBLCTRL.txsactive\_en

- REGB\_ARB\_PORT9.PCHBLCTRL.txsactive\_en
- REGB\_DDRC\_CH0.ADVECCINDEX.ecc\_err\_symbol\_sel
- REGB\_DDRC\_CH0.ADVECCINDEX.ecc\_poison\_beats\_sel
- REGB\_DDRC\_CH0.ADVECCINDEX.ecc\_syndrome\_sel
- REGB\_DDRC\_CH0.ADVECCSTAT.advecc\_corrected\_err
- REGB\_DDRC\_CH0.ADVECCSTAT.advecc\_err\_symbol\_bits
- REGB DDRC CHO.ADVECCSTAT.advecc err symbol pos
- REGB DDRC CH0.ADVECCSTAT.advecc num err symbol
- REGB\_DDRC\_CH0.ADVECCSTAT.advecc\_uncorrected\_err
- REGB\_DDRC\_CH0.ECCCFG0.ecc\_type
- REGB\_DDRC\_CH0.ECCCFG1.poison\_chip\_en
- REGB\_DDRC\_CH1.ADVECCSTAT.advecc\_corrected\_err
- REGB\_DDRC\_CH1.ADVECCSTAT.advecc\_err\_symbol\_bits
- REGB\_DDRC\_CH1.ADVECCSTAT.advecc\_err\_symbol\_pos
- REGB\_DDRC\_CH1.ADVECCSTAT.advecc\_num\_err\_symbol
- REGB\_DDRC\_CH1.ADVECCSTAT.advecc\_uncorrected\_err

# The following registers have been changed:

- Name of register
  - REGB\_ADDR\_MAP0.ADDRMAPLUTCFG.addrmap\_lut\_max\_active\_hif\_addr\_bit changed from REGB\_ADDR\_MAP0.ADDRMAPLUTCFG.addrmap\_lut\_max\_active\_hif\_addr\_bit to REGB\_ADDR\_MAP0.ADDRMAPLUTCFG.addrmap\_lut\_max\_active\_hif\_addr\_width.
- Name of register REGB\_ARB\_PORTO.SBRCTL.gen\_rmw changed from REGB\_ARB\_PORTO.SBRCTL.gen\_rmw to REGB\_ARB\_PORTO.SBRCTL.sbr\_correction\_mode.
- Name of register REGB\_ARB\_PORTO.SBRCTL.scrub\_burst\_length\_normal changed from REGB\_ARB\_PORTO.SBRCTL.scrub\_burst\_length\_normal to REGB\_ARB\_PORTO.SBRCTL.scrub\_burst\_length\_nm.
- RegisterResetValue of register REGB\_DDRC\_CH0.DDRCTL\_VER\_NUMBER.ver\_number changed from 0x3130302a to 0x3130312a.

For details, refer to the "Register Descriptions" chapter of the Programming Guide.

# 1.3.3 1.00a-lca01

# 1.3.3.1 Fixed Defects

- Both dfi\_init\_start and dfi\_phyupd\_ack can be asserted together (STAR 3213927).
- LPDDR5 ACT commands cannot be issued effectively when data rate is higher than 4800 (STAR 3158528)

- ACT is blocked by critical per-bank refresh for other bank (STAR 3101606)
- PHY master can cause Refresh interval violation (STAR 3109087)
- Incorrect behavior of VPR/W timeouts in dual channel configurations (STAR 9001485660)
- DFIUPDO.dis\_auto\_ctrlupd should be Quasi-dynamic Group 2 (STAR 9001509740)
- Issue with DFITMGO.dfi\_tphy\_wrlat/dfi\_tphy\_wrdata in frequency change procedure (STAR 9001511588)
- Scrubber's burst length is not equal to the programmed burst length register (STAR 3094530)

## 1.3.3.2 Enhancements

- Support for Dual RAQ with no AXI read data interleaving
- RRB Threshold Based VC Selection Feature for Read Data Interleaving Disabled Configuration
- Area efficient VTQ implementation in RRB
- Support Link ECC without enabling MEMC\_INLINE\_ECC
- Support for Single DDRC Single DFI configuration for LPDDR54
- Align LPDDR5 wck period after WCK Buffer timeout
- Support CAM and Read/Write Switching Enhancement in Dynamic BSM configuration
- Enhanced On-Chip Parity feature to corrupt ECC on write data when OCPAR write data parity error is detected in corresponding write data beat
- Improve management of ACT ordering for performance
- Minor timing closure improvement
- Add support UMCTL2\_PA\_OPT\_TYPE=2 for multiport AXI configurations.
  - a. Default value of UMCTL2\_PA\_OPT\_TYPE has changed. Up to 4 Internal ports default value of UMCTL2\_PA\_OPT\_TYPE value is 2; for more than 4 internal ports it is 1.
- Add support MEMC\_NO\_OF\_BLK\_CHANNE=32 in inline ECC configurations
- Improve clock gating ratio
- Add feature to hide ECCCSYN\* and ECCUSYN\* register value by new input pin dis\_regs\_ecc\_syndrome for security purpose. (ECC configurations only)
- Add support to generate multi-cycle path constraints when DDRCTL\_MCP\_INCLUDE=1

# 1.3.3.3 Hardware Parameter Changes

The following parameters have been added:

- DDRCTL\_SYS\_INTF parameter was added to select the System Interface for DDRC instead of UMCTL2\_INCL\_ARB
- UMCTL2\_RRB\_THRESHOLD\_EN\_n
- UMCTL2 PA OPT TYPE

# 1.3.3.4 Signal Changes

The following signals have been added:

■ dis\_regs\_ecc\_syndrome

# 1.4 Known Issues and Limitations

Table 1-1 lists unsupported features, as well as known issues and limitations in this version of the DDR Controller.

Table 1-1 Unsupported And Unverified Features in DWC LPDDR5/4/4X Controller

| Category        | Known Issues and Limitations                                                                                     | Notes                                                                                                      |
|-----------------|------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
| LPDDR5          | 8-bank mode is not supported.                                                                                    |                                                                                                            |
| LPDDR5          | BL32 is not supported.                                                                                           |                                                                                                            |
| LPDDR5          | Write X is not supported.                                                                                        |                                                                                                            |
| LPDDR5          | Data Copy is not supported.                                                                                      |                                                                                                            |
| LPDDR5          | CAS (B3) command (that is, Non-Zero Burst Start Address for RD) is not supported.                                | This limitation is only for HIF configuration (hif_address[3:0] must always be 0).                         |
| LPDDR5/4        | Data rate less than 1066Mbps is not fully verified.                                                              | Contact Synopsys for more information.                                                                     |
| LPDDR5/4        | DFI Low-Power Control Handshaking for data is not fully verified.                                                |                                                                                                            |
| LPDDR5/4        | Changing DFI frequency ratio dynamically is not supported.                                                       |                                                                                                            |
| LPDDR5          | DVFSC mode change is verified only during SR/SRPD.                                                               | Contact Synopsys for more information.                                                                     |
| LPDDR4          | HWFFC is supported only for LPDDR4/4X SDRAM with limited configuration.                                          | Data rate has to be within the range between 1066Mbps and 4266Mbps. Contact Synopsys for more information. |
| LPDDR5          | LPDDR5 HWFFC is not supported.                                                                                   |                                                                                                            |
| DFI or PHY      | Controller Assisted Drift Tracking for LPDDR4 (DQSOSC) is not recommended to be used.                            | Contact Synopsys for more information.                                                                     |
| DFI or PHY      | Changing DBI mode dynamically is not supported after initialization.                                             | LPDDR54 PHY does not support it.                                                                           |
| DFI or PHY      | DBI mode in the PHY is not verified (only DFIMISC.phy_dbi_mode=0 is supported).                                  |                                                                                                            |
| Config/topology | Controller HW cannot be configured as dual channel configuration (Only single DDRC can exist in the controller). | Refer to the databook for more details.                                                                    |

| Category                 | Known Issues and Limitations                                                                                                                    | Notes                                                                                                                                                                                                                                                                                                 |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Config/topology          | Only 1:4 HW configuration is supported (DFI 1:2 mode or DFI 1:4 mode can be chosen by TMGCFG register during reset).                            |                                                                                                                                                                                                                                                                                                       |
| Config/topology          | Half Bus Width (HBW) is supported only with MEMC_DATA_WIDTH=32 and 16-bit PHY.                                                                  | Refer to the databook for more details. For HBW mode, contact Synopsys for more information.                                                                                                                                                                                                          |
| Config/topology          | Quarter Bus Width (QBW) is not supported.                                                                                                       |                                                                                                                                                                                                                                                                                                       |
| Application<br>Interface | CHI is not supported in LPDDR5/4/4X Controller.                                                                                                 |                                                                                                                                                                                                                                                                                                       |
| Automotive               | ASIL- B Ready Certification packaged in this release is for Config1, Config2 and Config4. Config3 in FMEDA/Safety Manual is for reference only. | Contact Synopsys directly to agree usage of this Config3 in your application following future certification process.                                                                                                                                                                                  |
| ТВ                       | Warning-[FCPSBU] Invalid values in bin Warning-[FCIBR] Invalid bin range.                                                                       | To avoid these warnings, if UMCTL2_A_IDW is set to a larger value than 23, the following command needs to be executed in the command line of coreConsultant GUI or included it in your configuration batch file: set_activity_parameter DWC_ddrctl_Simulate suppress_warning_noFCPSBU_plus_no FCIBR 1 |
| ТВ                       | UVM_ERROR uvm_test_top [write_export_dfi] test_dwc_ddrctl_perf_vseq cast failed                                                                 | If DDRCTL_HW_RFM_CTRL is set to 1, this UVM_ERROR is expected to be seen in the test test_dwc_ddrctl_default_settings_lpddr5.                                                                                                                                                                         |